

WHAT IS CLAIMED:

1 1. A main memory simulator for simulating large computer memories, wherein said  
2 large computer memories are defined by a plurality of memory addresses, wherein each  
3 of said plurality of addresses contains data, and wherein said large computer memories  
4 are large enough to prevent simulation via the use of one-to-one memory to file  
5 addressing for all of said plurality of memory addresses, wherein said simulator  
6 comprises:

7 a memory cache; and

8 a processor operable with said memory cache, wherein said processor  
9 operates under instructions to move data contained in frequently used memory  
10 addresses of said plurality of memory addresses to said memory cache on a fast  
11 memory access basis and under instructions to move data contained in  
12 infrequently used memory addresses of said plurality of memory addresses to  
13 said memory cache on a slow memory access basis.

1 2. The simulator of claim 1, wherein said fast memory access comprises the  
2 utilization of a set of fast lookup tables to directly obtain a page address that has been  
3 allocated to the frequently used memory address.

1       3.     The simulator of claim 1, wherein said slow memory access comprises the  
2     utilization of a slow lookup table to first determine if a page address has been allocated  
3     to the infrequently used memory address and to then obtain the allocated page address.

1       4.     The simulator of claim 2, wherein said slow memory access comprises the  
2     utilization of a slow lookup table to determine if a page address has been allocated to the  
3     infrequently used memory address and the obtainment of said page address if allocated.

1       5.     The simulator of claim 1, wherein the movement of data is achieved through a  
2     page transfer.

1       6.     A main memory simulator for simulating large computer memories, wherein said  
2     large computer memories are defined by a plurality of memory addresses, wherein each  
3     of said plurality of addresses contains data, and wherein said large computer memories  
4     are large enough to prevent simulation via the use of one-to-one memory to file  
5     addressing for all of said plurality of memory addresses, wherein said simulator  
6     comprises:

7               means for storing data;

8               means for processing instructions, wherein said means for processing  
9     instructions is in communication with said means for storing data; and

10              means for providing instructions to said means for processing  
11     instructions, wherein said means for providing instructions provides the

12 instruction to transfer data by identifying a memory address of said data, wherein  
13 said memory address comprises at least one of said plurality of memory  
14 addresses;

15 wherein said means for processing instructions processes said instruction  
16 to transfer data by determining if said memory address of said data is a  
17 frequently or infrequently accessed memory address, and by transferring said  
18 data to said means for storing via a fast memory access scheme if said data is a  
19 frequently accessed memory address or by transferring said data to said means  
20 for storing via a slow memory access scheme if said data is an infrequently addressed  
21 memory address.

1 7. The simulator of claim 6, wherein fast memory access scheme comprises utilizing  
2 a set of fast lookup tables.

1 8. The simulator of claim 7, wherein said fast lookup tables enable said means for  
2 processing to directly obtain a page address corresponding to said frequently accessed  
3 address.

1 9. The simulator of claim 6, wherein said slow memory access scheme comprises  
2 utilizing a slow lookup table.

1 10. The simulator of claim 9, wherein said slow lookup table enables said means for  
2 processing to first determine if a page address has been allocated to said infrequently  
3 addressed memory address and then obtaining the allocated page address.

1 11. The simulator of claim 6, wherein said transferring of data is achieved through a  
2 page transfer.

1 12. A method for simulating large computer memories, wherein said large computer  
2 memories are defined by a plurality of memory addresses, wherein each of said plurality  
3 of addresses contains data, and wherein said large computer memories are large enough  
4 to prevent simulation via the use of one-to-one addressing for all of said plurality of  
5 memory addresses, the method comprising:

6 obtaining a request for transfer of data within at least one of said plurality  
7 memory addresses, wherein said request identifies the memory address of said at  
8 least one of said plurality of memory addresses containing said data;

9 determining whether the requested memory address is a frequently  
10 requested memory address or whether the requested memory is an infrequently  
11 requested memory address;

12 if the determination reveals a frequently requested memory address, then  
13 using a fast memory access scheme to transfer the data within said frequently  
14 requested memory address; and

15                   if the determination reveals an infrequently requested memory address,  
16                   then using a slow memory access scheme to transfer the data within said  
17                   infrequently requested memory address.

1    13.    The method of claim 12, wherein said fast memory access scheme comprises  
2    utilizing a set of fast lookup tables.

1    14.    The method of claim 13, wherein said fast lookup tables enable direct obtainment  
2    of a page address corresponding to said frequently accessed address.

1    15.    The method of claim 12, wherein said slow memory access scheme comprises  
2    utilizing a slow lookup table.

1    16.    The method of claim 15, wherein said slow lookup table first enables determining  
2    if a page address has been allocated to said infrequently addressed memory address and  
3    then enables obtaining the allocated page address.

1    17.    The method of claim 12, wherein said transfer of data comprises a page transfer.

1    18.    A memory simulation system for simulating a main memory of a computer,  
2    wherein the spaces of memory within said main memory are defined by a main memory  
3    address, the system comprising:

4                   a plurality of files, wherein said files include a fast look-up table and a slow  
5                   look-up table,

6                   wherein said fast look-up table is operable to directly obtain a page  
7                   address that has been allocated to said main memory address, and

8                   wherein said slow look-up table is operable to first determine if a page  
9                   address has been allocated to said main memory address and if a page address  
10                  has been allocated to said main memory address, to obtain the allocated page  
11                  address;

12                  a cache, wherein said cache includes a buffer; and

13                  an interface, wherein said interface receives a request for transfer of main  
14                  memory between at least one of said plurality of files and said buffer, wherein  
15                  said request is made through input of said main memory address to said  
16                  interface, and wherein in response to said request said interface performs a page  
17                  transfer between said at least one of said plurality of files and said buffer  
18                  according to the page address that has been allocated to said main memory  
19                  address via said fast look-up table or said slow look-up table.

1       19.   The system of claim 18, wherein said plurality of files further include a last access  
2       look-up table, wherein said last access look-up table includes a last memory address  
3       accessed and the page address allocated to said last memory address accessed.

1 20. The system of claim 18, wherein upon said interface performing a page transfer,  
2 said main memory address represented by the page is used to search a breakpoint list,  
3 and wherein upon finding that a word within said page has a breakpoint set as indicated  
4 by the search of said breakpoint list, a breakpoint flag within a page descriptor of said  
5 page is set.

1 21. The system of claim 18, wherein both said fast look-up table and said slow look-  
2 up table are savable into a finite number of files.

1 22. The system of claim 21, wherein said fast look-up table and said slow look-up  
2 table are restorable from the saved files enabling a previously stopped simulation to  
3 continue.

1 23. The system of claim 18, wherein said fast look-up table is used to obtain a page  
2 address for memory that is accessed frequently and wherein said slow look-up table is  
3 used to obtain a page address for memory that is accessed infrequently.

1 24. The system of claim 23, wherein said fast look-up table is divided into a plurality  
2 of banks, each bank having a defined number of words, and wherein the frequency of  
3 access is determined by dividing said main memory address by said defined number of  
4 words to obtain a quotient value, wherein said quotient value is compared against a

5 predetermined value, and wherein the comparison provides an indication of whether  
6 said main memory address is frequently or infrequently accessed.

1 25. A memory simulation system for simulating main memory of a computer,  
2 wherein the spaces of memory within said main memory are defined by a main memory  
3 address, the system comprising:

4 means for receiving a data transfer request, wherein said data transfer  
5 request is defined by a main memory address;

6 means for determining the frequency of use of said main memory address;

7 means for obtaining a page address corresponding to said main memory  
8 address, wherein said means for obtaining includes:

9 means for obtaining a page address corresponding to said main  
10 memory address when said main memory address has been determined to  
11 be frequently used; and

12 means for obtaining a page address corresponding to said main  
13 memory address when said main memory address has been determined to  
14 be infrequently used;

15 means for transferring data to a memory location, wherein said  
16 transferring of data comprises a page transfer in accordance with the obtained  
17 page address.

1 26. The system of claim 25, wherein said means for obtaining the page address of the  
2 frequently used main memory address comprises a set of fast lookup tables.

1 27. The system of claim 26, wherein said fast lookup tables enable said means for  
2 obtaining to directly obtain the page address of the frequently used main memory  
3 address.

1 28. The system of claim 25, wherein said means for obtaining the page address of the  
2 infrequently used main memory address comprises a slow lookup table.

1 29. The system of claim 28, wherein said slow lookup table enables said means for  
2 obtaining to first determine if a page address has been allocated to said main memory  
3 address and then to obtain that allocated pages address.

1 30. A method of memory transfer for use in simulating a main memory, wherein the  
2 spaces of memory within said main memory are defined by a main memory address, the  
3 method comprising:

4                   obtaining a main memory address, wherein said main memory address  
5                   indicates a request for a main memory transfer between a file and a cache buffer;  
6                   determining if said main memory address comprises memory that is  
7                   accessed frequently or infrequently;

8           if said main memory address comprises memory that is accessed  
9           frequently, directly obtaining a page address that has been allocated to said main  
10          memory address through use of a first look-up table;

11           if said main memory address comprises memory that is accessed  
12          infrequently, first determining whether a page address has been allocated to said  
13          main memory address, then obtaining the page address that has been allocated to  
14          said main memory address;

15           transferring the requested main memory between said file and said cache  
16          buffer via a page transfer that utilizes the page address allocated to said main  
17          memory address.

1    31.    The method of claim 30, further comprising the step of saving the last main  
2    memory address accessed and the corresponding page address.

1    32.    The method of claim 30, further comprising the step of searching a breakpoint  
2    list, wherein upon discovering that a word within the transferred page has a breakpoint  
3    set as indicated by the search of said breakpoint list, setting a breakpoint flag within a  
4    page descriptor of the transferred page.

1    33.    The method of claim 30, further comprising the step of saving said first look-up  
2    table and said second look-up table into a number of finite files.

1 34. The method of claim 33, further comprising the step of restoring said first look-  
2 up table and said second look-up table to continue a previously stopped simulation.

1 35. The method of claim 30, wherein said first look-up table is divided into a  
2 plurality of banks, each bank having a defined number of words, and wherein said step  
3 of determining is achieved by dividing said main memory address by said defined  
4 number of words to obtain a quotient value, then comparing said quotient value against  
5 a predetermined value, wherein the comparison provides an indication of whether said  
6 main memory address is frequently or infrequently addressed.